//设计一个支持 push ，pop ，top 操作，并能在常数时间内检索到最小元素的栈。
//
// 实现 MinStack 类:
//
//
// MinStack() 初始化堆栈对象。
// void push(int val) 将元素val推入堆栈。
// void pop() 删除堆栈顶部的元素。
// int top() 获取堆栈顶部的元素。
// int getMin() 获取堆栈中的最小元素。
//
//
//
//
// 示例 1:
//
//
//输入：
//["MinStack","push","push","push","getMin","pop","top","getMin"]
//[[],[-2],[0],[-3],[],[],[],[]]
//
//输出：
//[null,null,null,null,-3,null,0,-2]
//
//解释：
//MinStack minStack = new MinStack();
//minStack.push(-2);
//minStack.push(0);
//minStack.push(-3);
//minStack.getMin();   --> 返回 -3.
//minStack.pop();
//minStack.top();      --> 返回 0.
//minStack.getMin();   --> 返回 -2.
//
//
//
//
// 提示：
//
//
// -2³¹ <= val <= 2³¹ - 1
// pop、top 和 getMin 操作总是在 非空栈 上调用
// push, pop, top, and getMin最多被调用 3 * 10⁴ 次
//
//
// Related Topics 栈 设计 👍 1580 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
class MinStack {
    stack: any[];
    min : number;
    constructor() {
        this.stack = []
        this.min = Infinity
    }

    push(val: number): void {
        this.stack.push(val)
        if(val < this.min) this.min = val
    }

    pop(): void {
        let popVal = this.stack.pop()
        //? 每次删除时需要重新找到最小值
        if (popVal === this.min) {
            let sortS = [...this.stack]
            //? 需要考虑删除到为空时应该重新置为Infinity
            this.min = sortS.length === 0 ? Infinity : sortS.sort((a, b) => a - b)[0]
        }
        return popVal
    }

    top(): number {
        return this.stack[this.stack.length - 1]
    }

    getMin(): number {
        //? 这个必须是常数时间检索到 所以这个方法不能循环
        return this.min
    }
}

/**
 * Your MinStack object will be instantiated and called as such:
 * var obj = new MinStack()
 * obj.push(val)
 * obj.pop()
 * var param_3 = obj.top()
 * var param_4 = obj.getMin()
 */
//leetcode submit region end(Prohibit modification and deletion)
